package middle;

/**
 * 你是一个专业的小偷，计划偷窃沿街的房屋。每间房内都藏有一定的现金，影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统，如果两间相邻的房屋在同一晚上被小偷闯入，系统会自动报警。
 *
 * 给定一个代表每个房屋存放金额的非负整数数组，计算你 不触动警报装置的情况下 ，一夜之内能够偷窃到的最高金额。
 *
 * 链接：https://leetcode.cn/problems/house-robber
 * @author 胡宇轩
 * @Email: programboy@163.com
 */
public class HouseRobber {
    class Solution {
        public int rob(int[] nums) {
            int stealVal = nums[0];
            int notStealVal = 0;
            // 重点就是维护两个最大的值（偷和不偷的两个最大值）
            int maxVal = stealVal;
            int notMaxStealVal = 0;
            for (int i = 1; i < nums.length; i++) {
                int temp = stealVal;
                stealVal = notMaxStealVal + nums[i];
                notStealVal = temp;
                maxVal = Math.max(stealVal, maxVal);
                notMaxStealVal = Math.max(notStealVal, notMaxStealVal);
            }
            return maxVal;
        }
    }
}
